

# Agilent E9524A **Inverse Assembler for Xilinx MicroBlaze**

# **Design Guide**



# Notices

© Agilent Technologies, Inc. 2005

No part of this manual may be reproduced in any form or by any means (including electronic storage and retrieval or translation into a foreign language) without prior agreement and written consent from Agilent Technologies, Inc. as governed by United States and international copyright laws.

### **Manual Part Number**

#### E9524-97000

This manual is available online at www.agilent.com. It is not an orderable part.

### **Revision History**

E9524-97000, July 2005

Agilent Technologies, Inc. 1900 Garden of the Gods Road Colorado Springs, CO 80907 USA

### **Trademark Acknowledgements**

Windows and MS Windows are U.S. registered trademarks of Microsoft Corporation.

### Warranty

The material contained in this document is provided "as is." and is subject to being changed, without notice, in future editions. Further, to the maximum extent permitted by applicable law, Agilent disclaims all warranties, either express or implied, with regard to this manual and any information contained herein, including but not limited to the implied warranties of merchantability and fitness for a particular purpose. Agilent shall not be liable for errors or for incidental or consequential damages in connection with the furnishing, use, or performance of this document or of any information contained herein. Should Agilent and the user have a separate written agreement with warranty terms covering the material in this document that conflict with these terms, the warranty terms in the separate agreement shall control.

### **Technology Licenses**

The hardware and/or software described in this document are furnished under a license and may be used or copied only in accordance with the terms of such license.

# **Restricted Rights Legend**

If software is for use in the performance of a U.S. Government prime contract or subcontract, Software is delivered and licensed as "Commercial computer software" as defined in DFAR 252.227-7014 (June 1995), or as a "commercial item" as defined in FAR 2.101(a) or as "Restricted computer software" as defined in FAR 52.227-19 (June 1987) or any equivalent agency regulation or contract clause. Use, duplication or disclosure of Software is subject to Agilent Technologies' standard commercial license terms, and non-DOD Departments and Agencies of the U.S. Government will receive no greater than Restricted Rights as defined in FAR 52.227-19(c)(1-2) (June

1987). U.S. Government users will receive no greater than Limited Rights as defined in FAR 52.227-14 (June 1987) or DFAR 252.227-7015 (b)(2) (November 1995), as applicable in any technical data.

### **Safety Notices**

# CAUTION

A **CAUTION** notice denotes a hazard. It calls attention to an operating procedure, practice, or the like that, if not correctly performed or adhered to, could result in damage to the product or loss of important data. Do not proceed beyond a **CAUTION** notice until the indicated conditions are fully understood and met.

# WARNING

A WARNING notice denotes a hazard. It calls attention to an operating procedure, practice, or the like that, if not correctly performed or adhered to, could result in personal injury or death. Do not proceed beyond a WARNING notice until the indicated conditions are fully understood and met.

### **1** Introduction

In This Guide... 5 Product Overview 5 **Target System Requirements** 6 Supported processor 6 **Object files** 6 Supported compilers 6 Headers 6 **Equipment Required** 7 Logic analysis system 7 Logic analyzer cards 7 Table 1. Logic analyzer channels required 7 Probes 7

### 2 Designing Your Board

Overview of the Connectors9Designing the Headers10AMP MICTOR 38 connectors10Other connectors10Signal-To-Connector Mappings12MICTOR header12Bus and signal descriptions13

### 3 Example: Using XPS to Set Up an FPGA for the Inverse Assembler

Overview of the Example System 16 Routing the Required Signals to FPGA Pins 17 Building the Software 21

### Index



# In This Guide...

This *Design Guide* provides information to assist you in designing a board which will be compatible with the Agilent E9524A Inverse Assembler for Xilinx MicroBlaze. It tells you what signals are required by the decoder, and suggests how to route these signals to a header.

For information on using the decoder, see the online help which is installed with the decoder.

# **Product Overview**

The inverse assembler, used with an Agilent Technologies logic analyzer, allows you to reconstruct program flow by capturing the instruction address of every executed instruction, then looking up the associated opcode in the object file, and then decoding the opcode into a MicroBlaze mnemonic. The inverse assembler traces code flow only; it does not capture operand values or memory values.

The inverse assembler uses a small number of external FPGA signals, plus a clock signal. The number of signals depends on the size of the address space in which the program is executing.



# **Target System Requirements**

The inverse assembler has been designed to work with target systems meeting the following requirements:

### Supported processor

• Xilinx MicroBlaze processor core.

### **Object files**

- You must have access to the object files for the code which is executing on your target system.
- You must know the memory address where the object code is loaded.

### **Supported compilers**

• The gcc compiler which is shipped with Platform Studio 7.1.01i, or equivalent.

### Headers

- You must provide a way to connect logic analyzer probes to the signals on your target system:
  - You must route the required signals from the MicroBlaze core to external pins on the FPGA.
  - You must provide a way, such as a MICTOR header, to connect the logic analyzer probes to the signals.

# **Equipment Required**

# Logic analysis system

You need an Agilent 16900-series or 1680/90-series logic analyzer.

### Logic analyzer cards

The logic analyzer card(s) you use must support the speed of the bus you are probing.

The logic analyzer card(s) must provide enough channels to probe the headers on your target system.

| T.L     | 1              |            |          |
|---------|----------------|------------|----------|
| Table 1 | Logic analyze  | r channaic | roauroa  |
|         | LUGIC analyzei | Channels   | required |
|         |                |            |          |

| Probing scheme                               | Number of channels |
|----------------------------------------------|--------------------|
| up to 32 PC_EX signals<br>1 MICTOR connector | 32                 |

### Probes

You need an appropriate number of logic analyzer probes ("adapter cables") to connect the logic analyzer cables to the header on your target system. The probe must match the type of connector you have placed on your board. Agilent recommends a MICTOR connector and an Agilent E5346A or E5380A probe.

### **1** Introduction



# **Designing Your Board**

This chapter describes the factors you need to consider when designing and preparing your target system for logic analysis.

# **Overview of the Connectors**

You must provide either one AMP MICTOR 38 connector with the signal mappings shown in the following sections, or another connector which maps the signals to the same logic analyzer channels.



# **Designing the Headers**

### **AMP MICTOR 38 connectors**

The signal-to-connector mappings shown in this chapter assume you are using AMP MICTOR 38 connectors.

Each MICTOR 38 connector carries 32 signals plus two clocks (CLK1 for two logic analyzer pods). Probes (part number E5346A, sometimes called "high-density termination cables") are required to connect the logic analyzer cables to the MICTOR connector. These probes contain the required termination. One probe is required for every two logic analyzer pods.

To increase the structural support for the probes, you should use support shrouds on each connector.

For more information, including mechanical dimensions, see the *Agilent Technologies E5346A 38-Pin Probe and E5351A 38-Pin Adapter Cable Installation Note*, available from www.agilent.com.

#### **Design Considerations**

The connector must be close enough to the signal source so that the stub length created is less than  $^{1}/_{5}$  the  $t_{\rm r}$  (bus risetime). For PC board material, (er = 4.9) and  $\rm Z_{o}$  in the range of 50 - 80Ω, use a propagation delay of 160 ps/inch of stub.

Each probed signal line must be able to supply a minimum of 600 mV to the probe tip and handle a minimum of 90 k $\Omega$  shunted by 10 pF. The maximum input voltage to the logic analyzer is  $\pm 40V$  peak

### **Other connectors**

You may use other connector/probe combinations, including:

- Agilent soft touch connectorless probe
- Agilent pro series soft touch connectorless probe
- Samtec connector with Agilent Samtec probe

Design information for these connectors can be found on the web at www.agilent.com. If you use one of these connectors, route each signal to the same logic analyzer signal as shown for the MICTOR connector. For example, **PC\_EX 15** should always be connected to **D0 even** on the logic analyzer, regardless of which connector/probe combination is used.

# Signal-To-Connector Mappings

# **MICTOR** header

| Analyzer Pod | MicroBlaze Trace Signal |    | r pin #<br>view) | MicroBlaze Trace Signal | Analyzer Pod |
|--------------|-------------------------|----|------------------|-------------------------|--------------|
| 5V           | NC                      | 1  | 2                | NC                      | 12C          |
| 5V           | NC                      | 3  | 4                | NC                      | 12C          |
| CLK even     | VALID_INSTR             | 5  | 6                | CLOCK                   | CLK odd      |
| D15 even     | PC_EX 0 (MSB)           | 7  | 8                | PC_EX 16                | D15 odd      |
| D14 even     | PC_EX 1                 | 9  | 10               | PC_EX 17                | D14 odd      |
| D13 even     | PC_EX 2                 | 11 | 12               | PC_EX 18                | D13 odd      |
| D12 even     | PC_EX 3                 | 13 | 14               | PC_EX 19                | D12 odd      |
| D11 even     | PC_EX 4                 | 15 | 16               | PC_EX 20                | D11 odd      |
| D10 even     | PC_EX 5                 | 17 | 18               | PC_EX 21                | D10 odd      |
| D9 even      | PC_EX 6                 | 19 | 20               | PC_EX 22                | D9 odd       |
| D8 even      | PC_EX 7                 | 21 | 22               | PC_EX 23                | D8 odd       |
| D7 even      | PC_EX 8                 | 23 | 24               | PC_EX 24                | D7 odd       |
| D6 even      | PC_EX 9                 | 25 | 26               | PC_EX 25                | D6 odd       |
| D5 even      | PC_EX 10                | 27 | 28               | PC_EX 26                | D5 odd       |
| D4 even      | PC_EX 11                | 29 | 30               | PC_EX 27                | D4 odd       |
| D3 even      | PC_EX 12                | 31 | 32               | PC_EX 28                | D3 odd       |
| D2 even      | PC_EX 13                | 33 | 34               | PC_EX 29                | D2 odd       |
| D1 even      | PC_EX 14                | 35 | 36               | PC_EX 30 or GND         | D1 odd       |
| D0 even      | PC_EX 15                | 37 | 38               | PC_EX 31 or GND         | D0 odd       |

### **Bus and signal descriptions**

**PC\_EX** Required. The MicroBlaze program counter, from the MicroBlaze trace signals PC\_EX.

Only the active bits of PC\_EX need to be routed to the mictor connector. In general, the most significant bits and the least significant bits of PC\_EX do not need to be routed to the connector because they are static. This reduces the number of FPGA pins that are dedicated to MicroBlaze trace.

**Most significant bits** The upper n bits of PC\_EX do not need to routed to the connector because they are static.

For example, suppose your system has 1M byte of program memory. 1M byte can be addressed with 20 bits. The upper 12 bits of the 32-bit program counter are static and are not needed by the inverse assembler. They do not have to be routed to the connector.

You must route a contiguous set of PC-EX to the connector. For example, if you route PC\_EX12 and PC\_EX15, then you must also route PC\_EX13 and PC\_Ex14, even if fPC\_EX13 and PC\_Ex14 are static.

**Least significant bits** The least significant two bits of PC\_EX are always zero. This is because the MicroBlaze instructions always start on 4-byte boundaries. The least significant two bits of PC\_EX are represented by MICTOR pins 36 and 38. Agilent recommends that these pins be grounded. There are two ways to do this:

• Ground the pins by connecting them to MicroBlaze Trace Signal PC\_EX 30 and PC\_EX 31 on the FPGA, or by connecting them to any other FPGA pins that are ground. This is the most straightforward method and provides maximum flexibility by allowing the connector pins to be used to probe any FPGA signal when they are not being used for MicroBlaze debug. This method has the disadvantage of using two pins of the FPGA to provide two bits of zero when the connector is used for MicroBlaze debug. • Ground the pins by connecting them to a board ground. This has the benefit of not using two pins of the FPGA, but it has the disadvantage of eliminating pins 36 and 38 of the MICTOR connector from any other use.

It is possible, but not recommended, to use MICTOR pins 36 and 38 for signals totally unrelated to the MicroBlaze core. In this case, set an option in the inverse assembler is to indicate that the least significant two bits of PC\_EX have not been provided to the logic analyzer. This has no adverse impact on the inverse assembler, but it does make logic analyzer triggers more complicated. To set a trigger on a program counter address, you will need to shift the address right by two bits. For example, to trigger on an instruction at 001C 1344, the logic analyzer trigger would be set to 007 04D1.

- **VALID\_INSTR** Required. True when PC\_EX is valid. One bit wide. This is the MicroBlaze VALID\_INSTR signal.
  - **CLOCK** Required. The logic analyzer also uses the MicroBlaze CLOCK signal. A logic analyzer state is captured for each clock cycle; the clock is not displayed as a bus or signal.
    - **NC** Pins 1, 2, 3, and 4 must be true no-connects. Other NC signals can be left floating (no connects), or used to measure other signals of interest.



# Example: Using XPS to Set Up an FPGA for the Inverse Assembler

This chapter gives an example of how to set up an FPGA and get the signals required by the inverse assembler to appear on the FPGA pins, using the Xilinx Platform Studio (XPS) 7.1i.

NOTE

3

This is only an example. The steps you need to follow for your system will be different.



# **Overview of the Example System**



The sample design is an Agilent Technologies demo board.

At the center of the board is a Xilinx XC2V250 device. Connected to this device are logic analyzer connectors, P6, P7, P8, P9, P10 and P11. Also connected to the FPGA is an 8 bit pattern generator connector P4. For memory operations component U7 is used. This component is a Cypress 16K static ram is with an address to data valid time (taa) of 10 nS.

# **Routing the Required Signals to FPGA Pins**

Route the signals to external pins by adding external ports and modifying the UCF file:

- 1 In XPS, select Project->Add/Edit Cores.
- 2 Select the **Ports** tab.



**3** Check the **Show ports with default connections** box. This makes all MicroBlaze signals visible.

| Add/Edit Hardware Plat   | form Specificat | ions  |                    | <u> </u>                                             |
|--------------------------|-----------------|-------|--------------------|------------------------------------------------------|
| Peripherals   Bus Connec | tions Addresses | Ports | Parameters         |                                                      |
| External Ports C         |                 |       |                    | Show ports with default connections<br>Ports Filter: |
| Dort Name                | Vot Name        | Pola  | Danne Clace Sencit |                                                      |

4 Select PC\_EX and VALID\_INSTR and click <<Add.

| External Ports                                                                           | ections Addresses                                                    | 1                                                               | Paramete                                |                                                                     |          |   |                              | Show ports with default con                                                                                                                                                                                                               | nectio |
|------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------|---------------------------------------------------------------------|----------|---|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
| Port Name                                                                                | Net Name                                                             | Pola                                                            | Range                                   | Class                                                               | Sensit   |   |                              |                                                                                                                                                                                                                                           | -      |
| fpga_0_LEDS_GP                                                                           | fpga_0_LEDS_GPI                                                      | OUT                                                             | [0:1]                                   | l)                                                                  |          |   |                              | List of Ports. Click Add to add p                                                                                                                                                                                                         | cete . |
| fpga_0_DIP_Swit                                                                          | fpga_0_DIP_Switc                                                     | IN                                                              | [0:15]                                  |                                                                     |          |   |                              | Construction and the second                                                                                                                           | Cito   |
| sys_clk_pin                                                                              | dcm_clk_s                                                            | IN                                                              |                                         |                                                                     |          |   |                              | IM_REQUEST<br>IM_RNW                                                                                                                                                                                                                      | -      |
| sys_rst_pin                                                                              | sys_rst_s                                                            | IN                                                              |                                         |                                                                     |          |   |                              | IM_SELECT<br>IM_SEQADDR                                                                                                                                                                                                                   |        |
|                                                                                          |                                                                      |                                                                 |                                         |                                                                     |          |   | Add Port                     | IOPB_MGRANT<br>IOPB_RETRY                                                                                                                                                                                                                 |        |
| nternal Ports Connect                                                                    | ions:                                                                |                                                                 |                                         |                                                                     |          |   |                              | IOPB_TIMEOUT<br>IOPB_XFERACK<br>DBG_CLK<br>DBG_TDI<br>DBG_TD0                                                                                                                                                                             |        |
|                                                                                          | ions:<br>Port Name                                                   | Net Nar                                                         | me                                      | Po                                                                  | J Range  | - |                              | IOPB_TIMEOUT<br>IOPB_XFERACK<br>DBG_TLK<br>DBG_TDI<br>DBG_TDO<br>DBG_REG_EN<br>DBG_REG_EN<br>DBG_CAPTURE                                                                                                                                  |        |
| Instance                                                                                 |                                                                      | Net Nar<br>dcm_0_                                               | 117.0                                   | • 1                                                                 | i Range  | - | Make<br>External             | IOPB_TIMEOUT<br>IOPB_XFERACK<br>DBG_TCLK<br>DBG_TDU<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_UPDATE                                                                                                                                            |        |
| Instance<br>dcm_0                                                                        | Port Name                                                            | distantia orres                                                 | FB                                      | • 1<br>• 1                                                          | il Range | - |                              | IOPB_TIMEOUT<br>IOPB_XFERACK<br>DBG_CLK<br>DBG_TD0<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_UPDATE<br>VALID_INSTR<br>PC_EX                                                                                                                     |        |
| Instance<br>dcm_0<br>dcm_0<br>dcm_0<br>dcm_0                                             | Port Name<br>CLKFB<br>RST<br>LOCKED                                  | dcm_0_<br>net_gno<br>dcm_0_                                     | FB<br>d<br>Jock                         | • I<br>• I<br>• 0                                                   | il Range | - |                              | IOPB_TIMEOUT<br>IOPB_XFERACK<br>DBG_TDI<br>DBG_TDI<br>DBG_TDO<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_CAPTURE<br>DBG_UPDATE<br>VALID_INSTR<br>PC_EX<br>REG_WRITE                                                                              |        |
| Instance<br>dcm_0<br>dcm_0<br>dcm_0<br>mb_opb                                            | Port Name<br>CLKF8<br>RST<br>LOCKED<br>SYS_Rst                       | dcm_0_<br>net_gno                                               | FB<br>d<br>Jock                         | • I<br>• I<br>• 0<br>• I                                            | I Range  | - | External                     | IOPE_TIMEOUT<br>IOPE_XFERACK<br>DBG_TL0<br>DBG_TD0<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_CAPTURE<br>DBG_UPDATE<br>VALID_INSTR<br>PC_EX<br>REG_VRITE<br>REG_ADDR<br>MSR_REG                                                                  |        |
| Instance<br>dcm_0<br>dcm_0<br>dcm_0<br>mb_opb<br>mb_opb                                  | Port Name<br>CLKFB<br>RST<br>LOCKED<br>SYS_Rst<br>OPB_CIk            | dcm_0_<br>net_gno<br>dcm_0_                                     | FB<br>d<br>Jock<br>_S                   | • I<br>• 0<br>• I<br>• I                                            | I Range  | - | External                     | IDPB_TIMEOUT<br>IDPB_XFERACK<br>DBG_CLK<br>DBG_TDU<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_UPDATE<br>VALID_INSTR<br>PC EX<br>REG_WAITE<br>REG_ADDR<br>MSW_REG_VALUE                                                                           |        |
| nternal Ports Connect<br>Instance<br>dcm_0<br>dcm_0<br>dcm_0<br>mb_opb<br>imb_opb<br>imb | Port Name<br>CLKF8<br>RST<br>LOCKED<br>SYS_Rst                       | dcm_0_<br>net_gno<br>dcm_0_<br>sys_rst,<br>sys_rst,<br>sys_rst, | FB<br>d<br>Jock<br>_s<br>_s<br>_s       | I     I     I     I     I     I     I     I     I     I     I     I | I Range  | - | External                     | IOPB_TIMEOUT<br>IOPB_XFERACK<br>DBG_TL0<br>DBG_TD0<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_CAPTURE<br>DBG_UPDATE<br>VALID_INSTR<br>PC_EX<br>REG_VRITE<br>REG_ADDR<br>MSR_REG_VALUE<br>PIPE_RUNNING                                            |        |
| Instance<br>dcm_0<br>dcm_0<br>dcm_0<br>mb_opb<br>imb<br>imb                              | Port Name<br>CLKFB<br>RST<br>LOCKED<br>SYS_Rst<br>OPB_CIk            | dcm_0_<br>net_gno<br>dcm_0_<br>sys_rst,<br>sys_clk,             | FB<br>d<br>Jock<br>_s<br>_s<br>_s       |                                                                     | I Range  | _ | External                     | IOPE_TIMEOUT<br>IOPE_XFERACK<br>DBG_TDI<br>DBG_TDI<br>DBG_TDO<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_UPDATE<br>DBG_UPDATE<br>VALID_INSTR<br>PC_BX<br>REG_WRITE<br>REG_ADDR<br>MSR_REG_VALUE<br>PIPE_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN |        |
| Instance<br>dcm_0<br>dcm_0<br>dcm_0<br>mb_opb<br>mb_opb<br>imb                           | Port Name<br>CLKFB<br>RST<br>LOCKED<br>SYS_Rst<br>OPB_CIK<br>SYS_Rst | dcm_0_<br>net_gno<br>dcm_0_<br>sys_rst,<br>sys_rst,<br>sys_rst, | FB<br>d<br>Jock<br>_S<br>_S<br>_S<br>_S | I     I     I     I     I     I     I     I     I     I     I     I | N Range  |   | External<br><< Add<br>Delete | IOPB_TIMEOUT<br>IOPB_XFERACK<br>DBG_CLK<br>DBG_TDU<br>DBG_TD0<br>DBG_REG_EN<br>DBG_CAPTURE<br>DBG_UPDATE<br>VALID_INSTR<br>PC_EX<br>REG_WPITE<br>REG_ADDR<br>MSR_REG_VALUE<br>PIPE_RUNNING<br>INTERRUPT_TAKEN                             |        |

- Add/Edit Hardware Platform Specifications × Peripherals Bus Connections Addresses Ports Parameters Show ports with default connections XE External Ports Connections: Ports Filter: Net Name Pola... Range Class Port Name Sensit... fpga\_0\_LED5\_GP... fpga\_0\_LED5\_GPI... OUT... [0:1] List of Ports. Click Add to add ports fpga\_0\_DIP\_Swit... fpga\_0\_DIP\_Switc... INPUT [0:14] DBG\_TDO ٠ sys\_clk\_pin dcm\_clk\_s INPUT DBG\_REG\_EN DBG\_REG\_EN DBG\_CAPTURE DBG\_UPDATE VALID\_INSTR PC\_EX REG\_WRITE REG\_ADDR MSR\_REG NEW REG\_VALUE PREFETCH\_ADDR MSR\_REG NITERRUPT\_TAKEN JUMP\_TAKEN PREFETCH\_ADDR MB\_Halled Trace\_DBay\_Slot Trace\_Data\_Address\_ Slot\_Trace\_Data\_Address\_ Trace\_Data\_Mrite Trace\_Data\_Mrite Trace\_Data\_Mrite Trace\_Data\_Read Trace\_Data\_Mrite Trace\_Data\_Mrite Trace\_Data\_Read Trace\_Data\_Mrite Trace\_Data\_Read sys\_rst\_pin sys\_st\_s INPUT microblaze\_0\_VAL... microblaze\_0\_VAL... O Delete microblaze\_0\_PC... microblaze\_0\_PC\_EX O [0:29] Add Port Internal Ports Connections Instance Port Name Net Name Pol... Range 🔺 Make dcm\_0 LOCKED . 0 dcm\_0\_lock External SYS\_Rst - I mb\_opb sys\_rst\_s mb\_opb OPB\_Clk sys\_dk\_s - 1 << Add - I SYS\_Rst sys\_rst\_s ilmb LMB\_Ck - 1 imb sys\_clk\_s Delete dlmb SYS\_Rst sys\_rst\_s - I LMB\_Clk • I dimb sys\_clk\_s Connect microblaze\_0 VALID INSTR microblaze\_0\_... . microblaze\_0 PC\_EX microblaze\_0\_... 💌 O [0:31] 4 . .
- **5** Select "VALID\_INSTR" in internal port connections and click **Make External**.

#### 6 Do the same for PC\_EX. For PC\_EX set the range to be [0:29].

| fpga_0_LEDS_GP     fpga       fpga_0_DIP_Swit     fpg       sys_dk_pin     dci       sys_rst_pin     sys       microblaze_0_VAL     microblaze | sjstjs                                                 | INPUT<br>INPUT<br>INPUT<br>O |        | Clas | 5   | Sensit |        | 1    | List of Ports. Click Add to add (        | <b>▼</b><br>ports |
|------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|------------------------------|--------|------|-----|--------|--------|------|------------------------------------------|-------------------|
| fpga_0_DIP_Swit fpg<br>sys_clk_pin dcr<br>sys_rst_pin sys<br>microblaze_0_VAL mic                                                              | ga_0_DIP_Switc<br>m_clk_s<br>s_rst_s<br>croblaze_0_VAL | INPUT<br>INPUT<br>INPUT<br>O |        |      |     |        |        |      | List of Ports. Click Add to add (        | ports             |
| sys_clk_pin dcr<br>sys_rst_pin sys<br>microblaze_0_VAL mic                                                                                     | m_clk_s<br>s_rst_s<br>croblaze_0_VAL                   | INPUT<br>INPUT<br>O          | [0:14] |      |     |        |        |      |                                          |                   |
| sys_rst_pin sys<br>microblaze_0_VAL mic                                                                                                        | s_rst_s<br>croblaze_0_VAL                              | INPUT<br>O                   |        |      |     |        |        |      | DDC TDO                                  | T DOCH            |
| microblaze_0_VAL mic                                                                                                                           | croblaze_0_VAL                                         | 0                            |        |      |     |        |        |      | DBG_TDO<br>DBG REG EN                    | -                 |
|                                                                                                                                                |                                                        |                              |        |      |     |        |        |      | DBG_CAPTURE                              |                   |
| microblaze_0_PC mic                                                                                                                            | croblaze_0_PC_EX                                       | 0                            |        |      |     |        | Dele   | ate  | DBG_UPDATE<br>VALID_INSTR                |                   |
|                                                                                                                                                |                                                        | ×                            | [0:29] |      |     |        | Lunnin | mind | PC_EX<br>REG_WRITE                       | _                 |
| nternal Ports Connections<br>Instance                                                                                                          | 7).                                                    | Net Nar                      | ne     | _    | Pol | Range  | -      |      | JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Halted |                   |
| dom_0 LO                                                                                                                                       | CKED                                                   | dcm_0_                       | lock   | *    | 0   |        | Mał    |      | Trace_Branch_Instr                       |                   |
| mb_opb SYS                                                                                                                                     | 5_Rst                                                  | sys_rst                      | 5      | -    |     |        | Exter  | mar  | Trace_Delay_Slot<br>Trace_Data_Address   |                   |
| mb_opb OP                                                                                                                                      | 8_Clk                                                  | sys_clk_                     | 5      | -    | 1   |        | << A   | dd   | Trace_AS                                 |                   |
| ilmb SYS                                                                                                                                       | 5_Rst                                                  | sys_rst_                     | 5      | •    |     |        | -      |      | Trace_Data_Read<br>Trace Data Write      |                   |
| imb LMI                                                                                                                                        | B_Clk                                                  | sys_dk_                      | 5      | -    | 1   |        | Dele   | ete  | Trace_DCache_Reg                         |                   |
| dimb SYS                                                                                                                                       | 5_Rst                                                  | sys_rst_                     | 5      | •    |     |        |        |      | Trace_DCache_Hit<br>Trace_ICache_Beg     |                   |
| dimb LMI                                                                                                                                       | B_Clk                                                  | sys_clk_                     | 5      | -    | I   |        | Conn   | nect | Trace_ICache_Hit                         |                   |
|                                                                                                                                                | LID_INSTR                                              | microbla                     | ze_0   | -    | 0   |        |        | 1000 | Trace_Instr_EX<br>FSL0_S_CLK             |                   |
|                                                                                                                                                | B_Clk                                                  | sys_clk_                     | 5      | •    | I   |        | Conn   | nect | Trace Instr EX                           |                   |

#### 3 Example: Using XPS to Set Up an FPGA for the Inverse Assembler

7 Add the MicroBlaze system clock (CLK) to an output. For this case the clock signal is called "sys\_clk\_s". This is done by clicking Add Port. Fill in as shown below and click OK.

| Add External Po  | ort       | <u>? ×</u> |
|------------------|-----------|------------|
| Port Name        |           |            |
| microblaze_clk   |           |            |
| Port Polarity    | OUT       | •          |
| Port Class       | NONE      | •          |
| Port Sensitivity |           | *          |
| Connected to     | sys_clk_s | •          |
|                  | OK        | Cancel     |

This is how your port setup should look:

| External Ports                                                                     | Connections:                                                                        |                                                                                          |                              |       |                                      |       | _     |                                        | Show ports with default cor<br>Ports Filter:                                                                                                                                                                                                                                                                                                                                                                                                                             | nnection |
|------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|------------------------------|-------|--------------------------------------|-------|-------|----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| Port Name                                                                          | Net Name                                                                            | Pola                                                                                     | Range                        | Clas  | s Se                                 | ensit |       |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |          |
| fpga_0_LEDS_GP                                                                     | fpga_0_LEDS_GPI                                                                     | OUT                                                                                      | [0:1]                        |       |                                      |       |       |                                        | List of Ports, Click Add to add p                                                                                                                                                                                                                                                                                                                                                                                                                                        | norts    |
| fpga_0_DIP_Swit                                                                    | fpga_0_DIP_Switc                                                                    | INPUT                                                                                    | [0:14]                       |       |                                      |       |       |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Incl     |
| sys_clk_pin                                                                        | dcm_clk_s                                                                           | INPUT                                                                                    |                              |       |                                      |       |       |                                        | DBG_TDO<br>DBG_REG_EN                                                                                                                                                                                                                                                                                                                                                                                                                                                    | -        |
| sys_rst_pin                                                                        | sys_rst_s                                                                           | INPUT                                                                                    |                              |       |                                      |       |       |                                        | DBG_CAPTURE                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |
| microblaze_0_VAL                                                                   | microblaze_0_VAL                                                                    | 0                                                                                        |                              |       |                                      |       |       |                                        | DBG_UPDATE                                                                                                                                                                                                                                                                                                                                                                                                                                                               |          |
| microblaze_0_PC                                                                    | microblaze_0_PC_EX                                                                  | 0                                                                                        | [0:29]                       |       |                                      |       |       | Delete                                 | VALUE INSTR                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |
|                                                                                    |                                                                                     |                                                                                          |                              |       |                                      |       |       | Delete                                 | VALID_INSTR<br>PC_EX                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |
| microblaze_clk                                                                     | sys_clk_s                                                                           | OUT                                                                                      |                              |       |                                      |       | ĺ     | Add Port                               | PC_EX<br>REG_WRITE<br>REG_ADDR<br>MSR_REG<br>NEW_REG_VALUE<br>PIPE_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN                                                                                                                                                                                                                                                                                                                                                              |          |
| -<br>nternal Ports Connect                                                         | ions:                                                                               |                                                                                          |                              |       | Del                                  | Denne | ĺ     |                                        | PC_EX<br>REG_WRITE<br>REG_ADDR<br>MSR_REG<br>NEW_REG_VALUE<br>PIPE_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR                                                                                                                                                                                                                                                                                                                                             |          |
| -<br>nternal Ports Connect<br>Instance                                             | ions:<br>Port Name                                                                  | Net Nar                                                                                  | 127.0                        |       | Pol                                  | Range | [     | Add Port                               | PC_EX<br>REG_ADDR<br>REG_ADDR<br>MSR_REG<br>NEW_REG_VALUE<br>PIPE_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Haled                                                                                                                                                                                                                                                                                                                    |          |
| nternal Ports Connect<br>Instance<br>dcm_0                                         | ions:<br>Port Name<br>LOCKED                                                        | Net Nan<br>dcm_0_                                                                        | lock                         | *     | 0                                    | Range | [     | Add Port                               | PC_EX<br>REG_ADDR<br>REG_ADDR<br>MSR_REG<br>NEW_REG_VALUE<br>PPE_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Haled<br>Trace_Branch_Instr<br>Trace_Blanch                                                                                                                                                                                                                                                                                             |          |
| nternal Ports Connect<br>Instance<br>dcm_0<br>mb_opb                               | ions:<br>Port Name<br>LOCKED<br>SYS_Rst                                             | Net Nan<br>dcm_0_<br>sys_rst_                                                            | lock<br>_s                   | -     | O<br>I                               | Range |       | Add Port<br>Make<br>External           | PC_EX<br>PEG_VMITE<br>PEG_ADDR<br>MSR_PEG<br>NEW_PEG_VALUE<br>PIPE_PUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Halted<br>Trace_Detay_Stat<br>Trace_Data_Address                                                                                                                                                                                                                                                                                      |          |
| -<br>nternal Ports Connect<br>Instance<br>dcm_0<br>mb_opb<br>mb_opb                | ions:<br>Port Name<br>LOCKED<br>SYS_Rst<br>OPB_CIk                                  | Net Nan<br>dcm_0_<br>sys_rst_<br>sys_clk_                                                | lock<br>_s<br>_s             | •     | 0<br>1<br>1                          | Range |       | Add Port                               | PC_EX<br>PEG_VMITE<br>PEG_ADDR<br>MSR_PEG<br>NEW_PEG_VALUE<br>PIPE_PUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Halled<br>Trace_Derach_Instr<br>Trace_Data_Address<br>Trace_Data_Read                                                                                                                                                                                                                                                                 |          |
| -<br>Instance<br>dcm_0<br>mb_opb<br>mb_opb<br>imb                                  | ions:<br>Port Name<br>LOCKED<br>SYS_Rst<br>OPB_CIk<br>SYS_Rst                       | Net Nan<br>dcm_0_<br>sys_rst_<br>sys_ck,<br>sys_rst_                                     | lock<br>_s<br>_s             | -     | 0<br>I<br>I<br>I                     | Range | [<br> | Add Port<br>Make<br>External<br><< Add | PC_EX<br>PEG_VMITE<br>REG_ADDR<br>MSR_REG<br>NEW_REG_VALUE<br>PRE_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Halted<br>Trace_Branch_Instr<br>Trace_Data_Address<br>Trace_AS                                                                                                                                                                                                                                                           |          |
| -<br>nternal Ports Connect<br>Instance                                             | ions:<br>Port Name<br>LOCKED<br>SYS_Rst<br>OPB_CIk<br>SYS_Rst                       | Net Nan<br>dcm_0_<br>sys_rst_<br>sys_clk_                                                | lock<br>_s<br>_s<br>_s<br>_s | • • • | 0<br>I<br>I<br>I<br>I                | Range | 1     | Add Port<br>Make<br>External           | PC.EX<br>PEG_VPITE<br>PEG_ADDR<br>MSR_REG<br>NEW_REG_VALUE<br>PREF_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>JUMP_TAKEN<br>MB_Halted<br>Trace_Data_hditess<br>Trace_Data_Matterst<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write                                                                                                                                          |          |
| nternal Ports Connect<br>Instance<br>dcm_0<br>mb_opb<br>imb<br>imb                 | ions:<br>Port Name<br>LOCKED<br>SYS_Rst<br>OPB_CIk<br>SYS_Rst<br>LMB_CIk            | Net Nan<br>dcm_0_<br>sys_rst_<br>sys_clk_<br>sys_rst_<br>sys_clk_                        | lock<br>_s<br>_s<br>_s<br>_s |       | O<br>I<br>I<br>I<br>I<br>I<br>I      | Range | -     | Add Port<br>Make<br>External<br><< Add | PC.EX<br>PEG_VMITE<br>PEG_ADDR<br>MSP_PEG<br>NEW_PEG<br>NEW_PEG<br>NEW_PEG<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Halled<br>Trace_Drach_Instr<br>Trace_Data_Address<br>Trace_Data_Matters<br>Trace_Data_Miter<br>Trace_Data_Miter<br>Trace_Data_Miter<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write |          |
| nternal Ports Connect<br>Instance<br>dcm_0<br>mb_opb<br>imb<br>imb<br>ilmb<br>dlmb | ions:<br>Port Name<br>LOCKED<br>SYS_Rat<br>OPB_CIk<br>SYS_Rat<br>LMB_CIk<br>SYS_Rat | Net Nan<br>dcm_0_<br>sys_rst<br>sys_clk_<br>sys_rst_<br>sys_clk_<br>sys_rst_<br>sys_clk_ | lock<br>_s<br>_s<br>_s<br>_s |       | 0<br>I<br>I<br>I<br>I<br>I<br>I<br>I | Range | -     | Make<br>External<br><< Add             | PC_EX<br>PEG_VMITE<br>PEG_ADDR<br>MSR_REG_VALUE<br>PIPE_RUNNING<br>INTERRUPT_TAKEN<br>JUMP_TAKEN<br>PREFETCH_ADDR<br>MB_Halled<br>Trace_Data_Address<br>Trace_Data_Address<br>Trace_Data_Mrite<br>Trace_Data_Mrite<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write<br>Trace_Data_Write       |          |

**8** Modify your UCF file. Add pin locations for the MicroBlaze trace outputs as shown in the example below. Note that the actual pin locations are user-defined.

```
# IA FPGA pins
Net microblaze_clk LOC=L16;
Net microblaze_0_VALID_INSTR LOC=L15;
```

| Net | <pre>microblaze_0_PC_EX&lt;29&gt; LOC=C12;</pre> |
|-----|--------------------------------------------------|
| Net | <pre>microblaze_0_PC_EX&lt;28&gt; LOC=B13;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;27&gt; LOC=D16;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;26&gt; LOC=D15;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;25&gt; LOC=D14;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;24&gt; LOC=E16;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;23&gt; LOC=E15;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;22&gt; LOC=E14;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;21&gt; LOC=F16;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;20&gt; LOC=F15;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;19&gt; LOC=G16;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;18&gt; LOC=G15;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;17&gt; LOC=K16;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;16&gt; LOC=K15;</pre> |
| Net | <pre>microblaze_0_PC_EX&lt;15&gt; LOC=B4;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;14&gt; LOC=A5;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;13&gt; LOC=B5;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;12&gt; LOC=C5;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;11&gt; LOC=A6;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;10&gt; LOC=B6;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;9&gt; LOC=D6;</pre>   |
| Net | <pre>microblaze_0_PC_EX&lt;8&gt; LOC=A7;</pre>   |
| Net | <pre>microblaze_0_PC_EX&lt;7&gt; LOC=B7;</pre>   |
| Net | <pre>microblaze_0_PC_EX&lt;6&gt; LOC=C7;</pre>   |
| Net | <pre>microblaze_0_PC_EX&lt;5&gt; LOC=A10;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;4&gt; LOC=B10;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;3&gt; LOC=D10;</pre>  |
| Net | <pre>microblaze_0_PC_EX&lt;2&gt; LOC=A11;</pre>  |
| Net | microblaze 0 PC EX<1> LOC=B11;                   |
| Net | microblaze 0 PC EX<0> LOC=C11;                   |
|     |                                                  |

# **Building the Software**

Once you have added the ports and modified the UCF file, build your software and download the FPGA bit file.

- 1 In XPS, select Tools>Generate Bitstream.
- 2 Select Tools->Generate Libraries and Bsps.
- **3** Set the compiler options.

| Optimizatio                    | on Parameters on Level No Optimization  the most optimized level.                                                                                                                                                              |
|--------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 🗖 Enabl                        | ilobal Pointer Optimization<br>e Profiling (deprecated, use -pg in advanced)<br>g xilprofile library must be included in SW platform                                                                                           |
| Create     Create     NOTE: If | tions<br>t generate debug symbols<br>: symbols for debugging (-g option)<br>: symbols for assembly (-gstabs option)<br>an optimization level is set, and -g is also set, the<br>ormation may not be correlated to source code. |
|                                |                                                                                                                                                                                                                                |

- 4 When you are done creating the application and setting the options, right-click the project name in the tree view and select Build Project to create the executable. Alternatively, select Tools> Compile Program Sources in XPS to build all of the applications.
- 5 After building the applications, XPS allows you to select the application that must be initialized in the generated bitstream. To initialize the hello\_world\_app executable in the bitstream, right-click on the project name hello\_world\_app in the tree view and select Mark to Initialize BRAMs. From the XPS main window, select Tools>Update Bitstream to initialize the BRAMs with the application's executable information.
- 6 Download fpga bit file "implementation/download.bit"

3 Example: Using XPS to Set Up an FPGA for the Inverse Assembler

# Index

## C

compilers, 6

# E

equipment required, 7

**X** XPS, 15

# Η

headers, 10

# L

logic analyzer cards number required, 7

# Μ

MICTOR connectors, 10

### Ρ

ports, 17 probes number required, 7 processors supported, 5

# S

Samtec probe, 10 soft touch probe, 10

# Т

trigger, 14

### U

UCF, 19

Index